

## WHAT IS CLAIMED IS:

1. An error correction device comprising: a buffer memory for storing at least one sector of data having a structure where each of N words of error correcting code comprises a data unit, an inner code parity unit, and one error detecting code; a syndrome calculating means for generating syndrome for data read from said buffer memory; an error correcting means for correcting error-containing data in said buffer memory by detecting an error position from the syndrome generated by said syndrome calculating means and by calculating an error value; an error detecting means for detecting an error, one sector at a time, in error-corrected data generated by said error correcting means; a storing means for storing mid-term results, in code word units, of an error detecting process in said error detecting means; a bus control means for controlling data transfer between said buffer memory, said syndrome calculating means, said error correcting means, and said error detecting means; and a system control means for performing various processes for error correction in predetermined procedures a necessary number of times, wherein

    said bus control means comprises:

20   a before-syndrome data transfer sub means for transferring data to be corrected from said buffer memory to said syndrome calculating means and to said error detecting means concurrently in code word units until said syndrome calculating means detects an error-containing code;

25   an after-syndrome data transfer sub means for, when said syndrome calculating means detects an error-containing code, transferring subsequent data in said buffer memory only to said syndrome calculating

means in code word units; and

an error-detecting data transfer sub means for, after said error correcting means corrects an error contained in data in said buffer memory based on the syndrome transmitted by said syndrome calculating means, 5 transferring error-corrected data which include the code word from which the error-containing code has been detected up to and including a final code word from said buffer memory to said error detecting means in code word units for error detection;

said error detecting means comprises:

10 a parallel process sub means for, until said syndrome calculating means detects an error-containing code, storing the mid-term results of the error detecting process to said storing means in code word units, and executing error detection of a code word transmitted from said buffer memory in parallel with syndrome calculation done by said syndrome calculating means; and

15 an after-correction error detecting sub means for, after said syndrome calculating means detects an error-containing code, executing error detection for data transferred from said buffer memory after the error correction done by said error correcting means, following a code word which has previous contents before the occurrence of an error and which is 20 already stored in said storing means.

2. The error detection device of claim 1 further comprising a DMA control means for controlling DMA transfer to said buffer memory, wherein 25 said system control means comprises:

00000000000000000000000000000000

a first DMA transfer sub means for providing said DMA control means with a first DMA transfer instruction indicating that data to be corrected should be transferred from said buffer memory to said syndrome calculating means and to said error detecting means at the start of an error 5 correcting process; and

a second DMA transfer sub means for, after having been informed of completion of error correction by said error correcting means, only when said syndrome calculating means has detected an error-containing code, providing said DMA control means with a second DMA transfer instruction 10 indicating that subsequent data including a code word from which said error-containing code has been detected based on error-containing code word information transmitted by said syndrome calculating means should be transferred from said buffer memory to said error detecting means; and  
said DMA control means comprises:

15 a transfer control sub means for making a request of said bus control means to perform DMA transfer in accordance with the first DMA transfer instruction and the second DMA transfer instruction transmitted by said system control means.

20 3. An error correction device comprising: a buffer memory for storing at least one sector of data having a structure where each of N words of error correcting code comprises a data unit, an inner code parity unit, and one error detecting code; a syndrome calculating means for generating syndrome for data read from said buffer memory; an error correcting 25 means for correcting error-containing data in said buffer memory by

100-94000-20000

detecting an error position from the syndrome generated by said syndrome calculating means and by calculating an error value; an error detecting means for detecting an error, one sector at a time, in error-corrected data generated by said error correcting means; a bus control means for controlling data transfer between said buffer memory, said syndrome calculating means, said error correcting means, and said error detecting means; and a system control means for performing various processes for error correction in predetermined procedures a necessary number of times; wherein

10        said bus control means comprises:

      a concurrent data transfer sub means for transferring data to be corrected from said buffer memory to said syndrome calculating means and to said error detecting means concurrently in code word units until said syndrome calculating means detects an error-containing code; and

15        an error-detecting data transfer sub means for, only when said syndrome calculating means has detected an error-containing code, after the error correction done by said error correcting means, transferring data in a sector containing error-corrected data in and after the code word from which the error-containing code has been detected, from said buffer memory to said error detecting means for error detection,

20        said error detecting means comprises:

      a parallel error detecting sub means for executing error detection for a code word transmitted from said buffer memory, in parallel with the syndrome calculation done by said syndrome calculating means; and

25        an error re-detecting sub means for, only when said syndrome

calculating means has detected an error-correcting code, executing error detection one more time for the error-corrected data.

4. The error correction device of claim 3 further comprising a DMA  
5 control means for controlling DMA transfer to said buffer memory, wherein  
said system control means comprises:

a first DMA transfer sub means for providing said DMA control means with a first DMA transfer instruction indicating that data to be corrected should be transferred from said buffer memory to said syndrome  
10 calculating means and to said error detecting means at the start of an error correcting process; and

a second DMA transfer sub means for, after having been informed of completion of error correction by said error correcting means, only when said syndrome calculating means has detected an error-containing code,  
15 providing said DMA control means with a second DMA transfer instruction indicating that a sector containing the data from which said error-containing code has been detected should be transferred from said buffer memory to said error detecting means; and

said DMA control means comprises:

20 a transfer control sub means for making a request of said bus control means to perform DMA transfer in accordance with the first DMA transfer instruction and the second DMA transfer instruction transmitted by said system control means.

25 5. An error correction device comprising: a buffer memory for

DOCUMENT EDITION 00000000

storing at least one sector of data having a structure where each of N words of error correcting code comprises a data unit, an inner code parity unit, and one error detecting code; a syndrome calculating means for generating syndrome for data read from said buffer memory; an error correcting  
5 means for correcting error-containing data in said buffer memory by detecting an error position from the syndrome generated by said syndrome calculating means and by calculating an error value; an error detecting means for detecting an error, one sector at a time, in error-corrected data generated by said error correcting means; a storing means for storing  
10 mid-term results, in code word units, of an error detecting process in said error detecting means; a bus control means for controlling data transfer between said buffer memory, said syndrome calculating means, said error correcting means, and said error detecting means; and a system control means for performing various processes for error correction in  
15 predetermined procedures a necessary number of times, wherein

    said bus control means comprises:

        a first transfer sub means for executing a first transfer where data to be corrected are transferred in code word units from said buffer memory concurrently to said syndrome calculating means and to said error detecting means until said syndrome calculating means detects an error-containing code, and for suspending the first transfer when said syndrome calculating means has detected an error-containing code; and  
20

        a second transfer sub means for executing a second transfer where a code word from which an error has been detected and corrected is transferred from said buffer memory to said error detecting means after  
25

the error correction done by said error correcting means, based on the syndrome transmitted from said syndrome calculating means; and

5 a first transfer resuming sub means for, after the completion of the second transfer, making the first transfer sub means resume the first transfer for subsequent code words including the code word which has been subjected to the second transfer, and

said error detecting means comprises:

10 a first error detecting sub means for, until said syndrome calculating means detects an error-containing code, executing a first error detection where error detection is performed for a code word transmitted from said buffer memory in parallel with the syndrome calculation done by said syndrome calculating means, while storing mid-term results of the error detection in code word units to said storing means;

15 a second error detecting sub means for, after said syndrome calculating means detects an error-containing code, executing a second error detection where error detection is resumed for code words whose errors have been detected and corrected by said error correcting means, starting at a code word which has previous contents before the occurrence of an error and which is already stored in said storing means; and

20 a first error detection resuming sub means for, after the completion of the second error detection for the error-corrected code word, making the first error detecting sub means resume the first error detection for subsequent code words.

25 6. The error correction device of claim 5 further comprising a DMA

CONFIDENTIAL

control means for controlling DMA transfer to said buffer memory, wherein said system control means comprises:

a DMA transfer instruction sub means for providing said DMA control means with a DMA transfer instruction indicating that data to be corrected  
5 should be transferred from said buffer memory to said syndrome calculating means and to said error detecting means at the start of an error correcting process; and

10 said DMA control means comprises a data transfer control sub means for making a request of said bus control means to perform DMA transfer in accordance with the DMA transfer instruction transmitted by said system control means.

7. An error correction device comprising; a buffer memory for storing at least one ECC block of data having a structure where a plurality  
15 of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to error correction; a syndrome calculating means for generating syndrome for data read from said buffer memory; an error correcting means for correcting error-containing data in said buffer memory by detecting an error position from the syndrome generated by said syndrome calculating means and by calculating an error  
20 value; an error detecting means for detecting an error in error-corrected  
25

data generated by said error correcting means; a bus control means for controlling data transfer between said buffer memory, said syndrome calculating means, said error correcting means, and said error detecting means; and a system control means for performing various processes for  
5 error correction in predetermined procedures a necessary number of times, wherein

    said system control means comprises:

        a first-time error correction sub means for reading data from said buffer memory in a same direction as calculation for an error detecting code  
10 as a first-time error correction; for transferring the read data to said syndrome calculating means and to said error detecting means concurrently until said syndrome calculating means detects an error-containing code; for making said syndrome calculating means execute syndrome calculation and said error detecting means execute error  
15 detection in parallel; for making said error correcting means execute error correction when said syndrome calculating means has detected an error-containing code; and for making one of said syndrome calculating means and said error correcting means provide the system control means with information which designates a code word containing the  
20 error-containing code;

        an even-numbered error correction sub means for reading a code word in a different direction from a preceding odd-numbered error correction; for transferring the code word to said syndrome calculating means and to said error detecting means concurrently until said syndrome calculating means  
25 detects an error-containing code; for making said syndrome calculating

CONFIDENTIAL

means execute syndrome calculation and said error detecting means execute error detection in parallel; for making said error correcting means execute error correction when said syndrome calculating means detects an error-containing code; and for making said error correcting means provide 5 said system control means with information which designates the position of the error-containing code in an error correcting code word obtained in the error correction;

10 a non-error range designating sub means for designating, one sector at a time, a range from which an error-containing code has not been detected at the odd-numbered error correction or the subsequent even-numbered error correction, based on said information that designates the code word including the error-containing code and said information that designates the position of the error-containing code in the error 15 correcting code word;

20 15 an odd-numbered error correction sub means for, as an odd-numbered error correction as a third-time or later error correction, providing concurrently said syndrome calculating means and said error detecting means with a code in the same direction as in the previous odd-numbered error correction except for a sector in one ECC block which has been designated by said non-error range designating sub means as the range 25 from which an error-containing code has not been detected in and before the preceding even-numbered error correction until said syndrome calculating means detects an error-containing code; for making said syndrome calculating means execute syndrome calculation and said error detecting means execute error detection in parallel; for making said error

correcting means execute error correction when said syndrome calculating means detects an error-containing code; and for making one of said syndrome calculating means and said error correcting means provide said system control means with information which designates the code word  
5 including the error-containing code; and

a number-of-times control sub means for repeating the odd-numbered error correction and the even-numbered error correction a predetermined number of times.

10 8. The error correction device of claim 7, wherein said number-of-times control sub means is a three-time repetition control sub means for repeating the error correction three times at most.

Sub a II > 9. The error correction device of claim 7 or 8 further comprising a  
15 storing means for storing mid-term results, in code word units, of each code word from which no error has been detected in the error detecting process done by said error detecting means until said syndrome calculating means detects an error-containing code, wherein

20 said non-error range designating sub means is a non-error sector code word range designating sub means for designating, in code word units of a sector, a range from which an error-containing code has not been detected in the odd-numbered error correction or the subsequent even-numbered error correction, based on said information that designates the code word including the error-containing code and on said information that designates  
25 the position of the error-containing code in the error correcting code word;

and

5        said odd-numbered error correction sub means is an odd-numbered error correction sub means with mid-term results for, in the third-time or later odd-numbered error correction, making said bus control means start a concurrent data transfer not at the head but at the code word of the sector from which an error-containing code has been detected, based on the information designated by said non-error sector code word range designating sub means; for making said syndrome calculating means start syndrome calculation at the code word; and for making said error detecting means start error detection at a code word somewhere in the middle of the sector by using contents stored in said storing means as an initial value.

10. The error correction device of claim 7 or 8 further comprising a sector-basis storing means for storing mid-term results, on a 15 sector-by-sector basis, in code word units, of each code word from which no error has been detected in the error detecting process done by said error detecting means, until said syndrome calculating means detects an error-containing code, wherein

20        said non-error range designating sub means is a sector-basis non-error code word range designating sub means for designating, on a sector-by-sector basis, in code word units, a range from which an error-containing code has not been detected in the odd-numbered error correction or the subsequent even-numbered error correction, based on said information that designates the code word including the error-containing 25 code and on said information that designates the position of the

error-containing code in the error correcting code word; and

5 said odd-numbered error correction sub means is an odd-numbered error correction sub means with mid-term results for, in the third-time or later odd-numbered error correction, making said bus control means start a concurrent data transfer not at the head but at the code word of each sector from which an error-containing code has been detected, based on the information designated by said sector-basis non-error code word range designating sub means; for making said syndrome calculating means start syndrome calculation at the code word; and for making said error detecting 10 means start error detection at a code word somewhere in the middle of the sector by using contents stored in said sector-basis storing means as an initial value.

11. The error correction device of claim 7 or 8 further comprising a 15 sector-group-basis storing means for storing mid-term results, on a sector-group-by-sector-group-basis, in code word units, of each code word from which no error has been detected in the error detecting process done by said error detecting means until said syndrome calculating means detects an error-containing code, wherein

20 said non-error range designating sub means is a sector-group-basis non-error code word range designating sub means for designating, on a sector-group-by-sector-group-basis, in code word units, a range from which an error-containing code has not been detected in the odd-numbered error correction or the subsequent even-numbered error correction, based on said 25 information that designates the code word including the error-containing

code and on said information that designates the position of the error-containing code in the error correcting code word; and

    said odd-numbered error correction sub means is an odd-numbered error correction sub means with mid-term results for, in the third-time or

5    later odd-numbered error correction, making said bus control means start a concurrent data transfer not at the head but at the code word of each sector group from which an error-containing code has been detected, based on the information designated by said sector-group-basis non-error code word range designating sub means; for making said syndrome calculating means  
10    start syndrome calculation at the code word; and for making said error detecting means start error detection at a code word somewhere in the middle of the sector by using contents stored in said sector-group-basis storing means as an initial value.

15    12. The error correction device of claim 1, 2, 5, 6, 7, or 8, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a  
20    plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

    said buffer memory is a plural-ECC-block-division buffer memory  
25    corresponding to a plurality of ECC blocks to be processed in parallel;

100-9406-10  
SEARCHED  
INDEXED  
SERIALIZED  
FILED

100-200-300-400-500-600-700-800-900  
said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

5 said system control means comprises:

10 a means-basis ECC block pipeline processing notification sub means for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

15 a means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing the error correction done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer memory done by said bus control means; for recognizing an ECC block in process when said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

20 an ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error 25 correction sub means, said number-of-times control sub means, and said

DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said plural-ECC-block-division buffer memory, and further notifying these same 5 sub means contained in said system control means of the ECC blocks which are in process therein.

13. The error correction device of claim 9, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a 10 structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction 15 (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

    said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting 20 process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

    said system control means comprises:

        a means-basis ECC block pipeline processing notification sub means 25 for transmitting ECC blocks which have been subjected to error correction

DETAILED DESCRIPTION

downstream; for storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

5        a means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing the error correction done by said error correcting means; for recognizing writing of  
10      error-corrected data to said plural-ECC-block-division buffer memory done by said bus control means; for recognizing an ECC block in process when said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

15      an ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control  
20      means that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

14. The error correction device of claim 10, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and 5 horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

10        said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

      said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

      said system control means comprises:

      a means-basis ECC block pipeline processing notification sub means for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

      a means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means

for error detection and error correction; for recognizing the error correction done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer memory done by said bus control means; for recognizing an ECC block in process when 5 said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

an ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said 10 even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said 15 plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

15. The error correction device of claim 11, wherein error correction 20 is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined 25 number of code words in the vertical direction or the horizontal direction

10282300-8741960

(data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

    said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

5       said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

    said system control means comprises:

10      a means-basis ECC block pipeline processing notification sub means for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said 15      error detecting means, and said error correcting means;

    a means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing the error correction 20      done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer memory done by said bus control means; for recognizing an ECC block in process when said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to 25      be processed; and

1000-031234560

an ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said  
5 DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which  
10 are in process therein.

*Sub a 12* > 16. The error correction device of claim 1, 2, 5, 6, 7, or 8, wherein  
error correction is performed in parallel for data in a plurality of ECC  
blocks each having a structure where a plurality of error correcting code  
15 words each comprising a data unit and a parity unit are arranged in  
vertical direction and horizontal direction so as to repeat error correction a  
plurality of number of times, and where predetermined data composed of a  
predetermined number of code words in the vertical direction or the  
horizontal direction (data in the horizontal direction are referred to as  
20 sector) as a unit are subjected to the error correction;

    said buffer memory is an ECC-block-basis buffer memory for storing,  
on a block-by-block basis, ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting  
process generated by said error detecting means is an ECC-block-and-code  
25 word-division storing means for storing ECC blocks in process on a

block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

said system control means comprises:

an means-basis ECC block pipeline processing notification sub means

5 for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said ECC-block-basis buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

10 a means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said 15 error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting 20 means; and

an ECC block code word recognition sub means in sub means-basis pipeline processing for making said first error detecting sub means, said even-numbered error correction sub means, said even-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means in said system control means

recognize that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said ECC-block-basis buffer memory, and further making these same sub means contained in said system control means recognize the ECC blocks and the 5 code words which are to be processed therein.

17. The error correction device of claim 9, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising 10 a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are 15 subjected to the error correction;

    said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-and-code 20 word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

    said system control means comprises:

        an means-basis ECC block pipeline processing notification sub means 25 for transmitting ECC blocks which have been subjected to error correction

downstream; for storing ECC blocks to be processed next to said ECC-block-basis buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

5 a means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said 10 error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting 15 means; and

an ECC block code word recognition sub means in sub means-basis pipeline processing for making said first error detecting sub means, said even-numbered error correction sub means, said even-numbered error correction sub means, said number-of-times control sub means, and said 20 DMA transfer instruction sub means in said system control means recognize that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said ECC-block-basis buffer memory, and further making these same sub means contained in said system control means recognize the ECC blocks and the 25 code words which are to be processed therein.

18. The error correction device of claim 10, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising 5 a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are 10 subjected to the error correction;

    said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-and-code 15 word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

    said system control means comprises:

        an means-basis ECC block pipeline processing notification sub means 20 for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said ECC-block-basis buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

25       a means-basis ECC block code word recognition sub means for

selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said 5 error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting 10 means; and

an ECC block code word recognition sub means in sub means-basis pipeline processing for making said first error detecting sub means, said even-numbered error correction sub means, said even-numbered error correction sub means, said number-of-times control sub means, and said 15 DMA transfer instruction sub means in said system control means recognize that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said ECC-block-basis buffer memory, and further making these same sub means contained in said system control means recognize the ECC blocks and the 20 code words which are to be processed therein.

19. The error correction device of claim 11, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising 25 a data unit and a parity unit are arranged in vertical direction and

horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are  
5 subjected to the error correction;

    said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-and-code  
10 word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

    said system control means comprises:

        an means-basis ECC block pipeline processing notification sub means  
15 for transmitting ECC blocks which have been subjected to error correction downstream; for storing ECC blocks to be processed next to said ECC-block-basis buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

20       a means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said  
25 error correcting means for error detection and error correction; in

controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting  
5 means;

an ECC block code word recognition sub means in sub means-basis pipeline processing for making said first error detecting sub means, said even-numbered error correction sub means, said even-numbered error correction sub means, said number-of-times control sub means, and said

10 DMA transfer instruction sub means in said system control means recognize that the error-corrected ECC blocks have been transmitted downstream and new ECC blocks to be processed have been stored in said ECC-block-basis buffer memory, and further making these same sub means contained in said system control means recognize the ECC blocks and the  
15 code words which are to be processed therein.

Sub  
a 13

20. The error correction device of claim 1, 2, 5, 6, 7, or 8 wherein  
error correction is performed in parallel for data in a plurality of ECC  
blocks each having a structure where a plurality of error correcting code  
20 words each comprising a data unit and a parity unit are arranged in  
vertical direction and horizontal direction so as to repeat error correction a  
plurality of number of times, and where predetermined data composed of a  
predetermined number of code words in the vertical direction or the  
horizontal direction (data in the horizontal direction are referred to as  
25 sector) as a unit are subjected to the error correction, wherein

the said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

said system control means comprises:

a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

15 a collective-type means-basis ECC block recognition sub means for  
recognizing a data transfer from said bus control means to said syndrome  
calculating means, to said error detecting means, and to said error  
correcting means for error detection and error correction; for recognizing  
the error correction done by said error correcting means; for recognizing  
20 writing of error-corrected data to said plural-ECC-block-division buffer  
memory by said bus control means; for recognizing ECC blocks in process  
when said error detecting means stores mid-term results to said  
plural-ECC-block-division storing means, and for selecting ECC blocks to  
be processed; and

25 a collective-type ECC block notification sub means in sub means-basis

pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

10

21. The error correction device of claim 9 wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

20 said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

25 said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

said system control means comprises:

a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC 5 blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

10 a collective-type means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing the error correction done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer 15 memory by said bus control means; for recognizing ECC blocks in process when said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

20 a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively 25 transmitted downstream and new ECC blocks to be processed have been

collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

5        22. The error correction device of claim 10, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of 10 times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

15        said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

      said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

20        said system control means comprises:

      a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said

syndrome calculating means, said error detecting means, and said error correcting means;

a collective-type means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing the error correction done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer memory by said bus control means; for recognizing ECC blocks in process

5 when said error detecting means stores mid-term results to said plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been

10 collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

23. The error correction device of claim 11, wherein error correction

25 is performed in parallel for data in a plurality of ECC blocks each having a

structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction, wherein

5        said buffer memory is a plural-ECC-block-division buffer memory corresponding to a plurality of ECC blocks to be processed in parallel;

10        said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-division storing means for storing said plurality of ECC blocks on a block-by-block basis;

      said system control means comprises:

15        a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

20        a collective-type means-basis ECC block recognition sub means for recognizing a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; for recognizing

the error correction done by said error correcting means; for recognizing writing of error-corrected data to said plural-ECC-block-division buffer memory by said bus control means; for recognizing ECC blocks in process when said error detecting means stores mid-term results to said 5 plural-ECC-block-division storing means, and for selecting ECC blocks to be processed; and

10 a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and 15 further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

20 *Sub A'4*

24. The error correction device of claim 1, 2, 5, 6, 7, or 8, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the 25 horizontal direction (data in the horizontal direction are referred to as

sector) as a unit are subjected to the error correction;

    said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

    said storing means for storing mid-term results of an error detecting 5 process generated by said error detecting means is an ECC-block-and-code word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

    said system control means comprises:  
10       a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said 15 syndrome calculating means, said error detecting means, and said error correcting means;

    a collective-type means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code 20 word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said 25 ECC-block-basis buffer memory done by said bus control means; in storing

mid-term results to said ECC-block-and-code word-division storing means by said error detecting means; and

a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

25. The error correction device of claim 9, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction;

said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

25 said storing means for storing mid-term results of an error detecting

process generated by said error detecting means is an ECC-block-and-code word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

5       said system control means comprises:

      a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

      a collective-type means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting means; and

      a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said

DO NOT PUBLISH - GOVERNMENT EDITION

even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

10 26. The error correction device of claim 10, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction;

15       said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

20       said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-and-code word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

05062018260

said system control means comprises:

a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

a collective-type means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means by said error detecting means; and

a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively

transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

5

27. The error correction device of claim 11, wherein error correction is performed in parallel for data in a plurality of ECC blocks each having a structure where a plurality of error correcting code words each comprising a data unit and a parity unit are arranged in vertical direction and horizontal direction so as to repeat error correction a plurality of number of times, and where predetermined data composed of a predetermined number of code words in the vertical direction or the horizontal direction (data in the horizontal direction are referred to as sector) as a unit are subjected to the error correction;

10 15 said buffer memory is an ECC-block-basis buffer memory for storing, on a block-by-block basis, ECC blocks to be processed in parallel;

20 said storing means for storing mid-term results of an error detecting process generated by said error detecting means is an ECC-block-and-code word-division storing means for storing ECC blocks in process on a block-by-block basis, and code words in each ECC block, in each sector, or in each sector group, on a string-by-string basis;

said system control means comprises:

25 a collective-type means-basis ECC block pipeline processing notification sub means for collectively transmitting ECC blocks which have been subjected to error correction downstream; for collectively storing ECC

CONFIDENTIAL - SECURITY

blocks to be processed next to said plural-ECC-block-division buffer memory; and for making the storage known to said bus control means, said syndrome calculating means, said error detecting means, and said error correcting means;

5 a collective-type means-basis ECC block code word recognition sub means for selecting code words of the ECC blocks to be processed, in accordance with the contents stored in said ECC-block-and-code word-division storing means, in controlling a data transfer from said bus control means to said syndrome calculating means, to said error detecting means, and to said error correcting means for error detection and error correction; in controlling the error correction done by said error correcting means; in controlling writing of error-corrected data to said ECC-block-basis buffer memory done by said bus control means; in storing mid-term results to said ECC-block-and-code word-division storing means

10 15 by said error detecting means; and

a collective-type ECC block notification sub means in sub means-basis pipeline processing for notifying said first error detecting sub means, said even-numbered error correction sub means, said odd-numbered error correction sub means, said number-of-times control sub means, and said DMA transfer instruction sub means contained in said system control means that the error-corrected ECC blocks have been collectively transmitted downstream and new ECC blocks to be processed have been collectively stored in said plural-ECC-block-division buffer memory, and further notifying these same sub means contained in said system control means of the ECC blocks which are in process therein.

28. An error correction device which performs error correction for data in ECC blocks each having a structure where error correcting code words each comprising a data unit and a parity unit are arranged in vertical and horizontal directions so as to realize repeated error correction, and predetermined data composed of a predetermined number of code words in the vertical or horizontal direction (data in the horizontal direction are referred to as sector) are as one unit subjected to error correction, and which also perform syndrome calculation and error detection in parallel with a storage of demodulated codes in a buffer memory, said error correction device comprising:

a first syndrome calculating means for performing syndrome calculation with said buffer memory;

a first error detecting means which pairs up with the first syndrome

a second syndrome calculating means for performing syndrome calculation of demodulated codes without said buffer memory;

a second error detecting means which pairs up with the second syndrome calculating means;

20 a storing means for storing mid-term results of calculations of the  
first error detecting means and the second error detecting means;

a buffer memory parallel transfer means for transferring data transmitted from upstream to the second syndrome calculating means and to the second error detecting means in parallel with storage of the data in said buffer memory until the second syndrome calculating means detects

an error-containing code;

an error-detecting-means switch means for switching between the first error detection means and the second error detection means in a manner that after the second syndrome calculating means detects an error-containing code, said storing means is provided with the mid-term results of the calculation by the second error detecting means of code words until said error-containing code is detected, and on and after the second-time error correction in a same direction, after the second syndrome calculating means detects an error-containing code, said storing means is provided with the mid-term results of the calculation by the second error detecting means of code words until said error-containing code is detected;

an error correcting means for performing error correction after one of the first error detecting means and the second error detecting means detects an error-containing code word;

a parallel transfer means for, on and after the second-time error correction in the same direction, before the first syndrome calculating means detects an error-containing code, transferring data stored in said buffer memory, starting at a code word which is not stored in said storing means to the first syndrome calculating means and to the first error detecting means; and

a second-time onward detecting-processed data use means for, on and after the second-time error detection in the same direction done by the second error detecting means, performing error detection of the subsequent code words by using the mid-term results stored in said storing means.

29. An error correction device which performs error correction for data in ECC blocks each having a structure where error correcting code words each comprising a data unit and a parity unit are arranged in vertical and horizontal directions so as to realize repeated error correction,  
5 and predetermined data composed of a predetermined number of strings in the vertical or horizontal direction (data in the horizontal direction are referred to as sector) are as one unit subjected to error correction, and which also perform syndrome calculation and error detection in parallel with a storage of demodulated codes in a buffer memory, said error  
10 correction device comprising:

a first syndrome calculating means for performing syndrome calculation with said buffer memory;

a first error detecting means which pairs up with the first syndrome calculating means;

15 a second syndrome calculating means for performing syndrome calculation of demodulated codes without said buffer memory;

a second error detecting means which pairs up with the second syndrome calculating means;

20 a storing means for storing mid-term results of calculations of the first error detecting means and the second error detecting means in predetermined data units such as ECC block units, sector units, and sector group units;

a buffer memory parallel transfer means for transferring data transmitted from upstream to the second syndrome calculating means and  
25 to the second error detecting means in said data units in parallel with

storage of the data in said buffer memory until the second syndrome calculating means detects an error-containing code;

an error-detecting-means switch means for switching between the first error detection means and the second error detection means in said

5 data units in a manner that after the second syndrome calculating means detects an error-containing code, said storing means is provided with the mid-term results of the calculation by the second error detecting means of code words until said error-containing code is detected, and on and after the second-time error correction in a same direction, after the second

10 syndrome calculating means detects an error-containing code, said storing means is provided with the mid-term results of the calculation by the second error detecting means of code words until said error-containing code is detected;

an error correcting means for performing error correction after one of the first error detecting means and the second error detecting means detects an error-containing code word;

a parallel transfer means for, on and after the second-time error correction in the same direction, before the first syndrome calculating means detects an error-containing code, transferring data stored in said buffer memory, starting at a code word which is not stored in said storing means to the first syndrome calculating means and to the first error detecting means; and

a second-time onward detecting-processed data use means for, on and after the second-time error detection in the same direction by the second error detecting means, performing error detection of the subsequent code

00000000000000000000000000000000

words by using the mid-term results stored in said storing means.

30. An error correction device which performs error correction for data in a plurality of ECC blocks each having a structure where error 5 correcting code words each comprising a data unit and a parity unit are arranged in vertical and horizontal directions so as to realize repeated error correction, and predetermined data composed of a predetermined number of code words in the vertical or horizontal direction (data in the horizontal direction are referred to as sector) are as one unit subjected to 10 concurrent or parallel error correction by pipeline processing, and which also perform syndrome calculation and error detection in parallel with a storage of demodulated codes in a buffer memory, said error correction device comprising:

15 a buffer memory for storing ECC blocks to be processed in pipeline, on a block-by-block basis;

a first syndrome calculating means for performing syndrome calculation;

a first error detecting means which pairs up with the first syndrome calculating means;

20 a second syndrome calculating means for performing syndrome calculation;

a storing means for storing the mid-term results of the calculation done by the first error detecting means and the second error detecting means in predetermined data units of the ECC blocks in process such as 25 ECC block units, sector units, or sector group units;

a demodulated-code calculation selecting means for making one of the first syndrome calculating means and the second syndrome calculating means execute syndrome calculation for demodulated data transmitted from upstream, and making the other syndrome calculating means execute syndrome calculation when there are data stored in said buffer memory;

a buffer memory parallel transfer means for, before the syndrome calculating means selected by said demodulated-code calculation selecting means detects an error-containing code, sequentially transferring data from upstream to the syndrome calculating means and the error detecting means which pairs up therewith, and at the same time storing the data in said buffer memory;

an error-detecting-means switch means for switching between the first error detection means and the second error detection means in a manner that after the syndrome calculating means selected by said demodulated-code calculation selecting means detects an error-containing code in data transmitted from upstream in said data units, said storing means is provided with the mid-term results of the calculation by the corresponding error detecting means of code words until said error-containing code is detected, and on and after the second-time error correction in a same direction, after the corresponding second syndrome calculating means detects an error-containing code, said storing means is provided with the mid-term results of the calculation by the corresponding error detecting means of code words until said error-containing code is detected;

25 an error correcting means for performing error correction after the

first error detecting means or the second error detecting means detects an error-containing code word;

a stored code calculation selecting means for selecting between the first syndrome calculating means and the second syndrome calculating means in ECC block units or in said data units so as to perform syndrome calculation for the data stored in said buffer memory;

a parallel transfer means for, on and after the second-time error correction in a same direction, before the first syndrome calculating means detects an error-containing code in said data units, transferring code words not stored in said storing means out of data stored in said buffer memory to the corresponding one of the first syndrome calculating means and the first error detecting means;

a second-time onward detecting-processed data use means for, on and after the second-time error detection in the same direction done by the corresponding error detecting means, performing error detection of the subsequent code words in said data units by using the mid-term results stored in said storing means;

a means-basis pipeline processing notification means for transmitting  
ECC blocks which have been subjected to error correction downstream; for  
20 storing ECC blocks to be processed next to said buffer memory; and for  
making the storage known to said stored code calculation selecting means,  
said buffer memory parallel transfer means, said error-detecting means  
switch means, the first syndrome calculating means, the second syndrome  
calculating means, said error detecting means, said error correcting means,  
25 said parallel transfer means, and said second-time onward

detecting-processed data use means; and

a system control means for controlling a data transfer and data rewriting of ECC blocks in process in ECC block units or said data units at each means and for coordinating with other means the transfer of  
5 error-corrected ECC blocks downstream and the storage of new ECC blocks to be processed in said buffer memory.

PROVISIONAL PATENT

*Sub  
a 15*

31. The error correction device of claim 1, 2, 3, 4, 5, 6, 7, 8, 28, 29, or  
30 further comprising:

10 two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction  
15 and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

20 32. The error correction device of claim 9 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous  
25 data of the predetermined capacity which are a target of error correction

and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

5

33. The error correction device of claim 10 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

10 a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

15 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

34. The error correction device of claim 11 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

20 a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

25 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error

PCT/EP2006/000650

correction alternately in units of said predetermined capacity.

35. The error correction device of claim 12 further comprising:

two buffer memories each having a predetermined capacity  
5 equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

10 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

36. The error correction device of claim 13 further comprising:

15 two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction  
20 and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

25 37. The error correction device of claim 14 further comprising:

CONTINUATION

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

5        a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

10        an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

38. The error correction device of claim 15 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

15        a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

20        an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

39. The error correction device of claim 16 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

25        a buffer memory storage means for alternately storing in said two

OCEN-2000-57446660

buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said  
5 two buffer memories in order to read or write data as a target of error  
correction alternately in units of said predetermined capacity.

40. The error correction device of claim 17 further comprising:

two buffer memories each having a predetermined capacity  
10 equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

15 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

41. The error correction device of claim 18 further comprising:

20 two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction  
25 and have been read from a DVD or a CD-ROM; and

CONTINUATION

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

5       42. The error correction device of claim 19 further comprising:  
two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

10      a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

15      an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

15       43. The error correction device of claim 20 further comprising:  
two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

20      a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

25      an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

44. The error correction device of claim 21 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

5 a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

10 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

45. The error correction device of claim 22 further comprising:

15 two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

20 an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

46. The error correction device of claim 23 further comprising:

25 two buffer memories each having a predetermined capacity

00000000000000000000000000000000

equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction  
5 and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

10 47. The error correction device of claim 24 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous  
15 data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

20

48. The error correction device of claim 25 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two  
25 buffer memories, in accordance with error correction speed, continuous

CROSS-REFERENCE TO RELATED APPLICATION

data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

49. The error correction device of claim 26 further comprising:

two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

10 a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

an accessed buffer memory switch means for switching between said two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.

50. The error correction device of claim 27 further comprising:

20 two buffer memories each having a predetermined capacity equivalent to one sector or one ECC block;

a buffer memory storage means for alternately storing in said two buffer memories, in accordance with error correction speed, continuous data of the predetermined capacity which are a target of error correction and have been read from a DVD or a CD-ROM; and

25 an accessed buffer memory switch means for switching between said

100-200-300-400-500

two buffer memories in order to read or write data as a target of error correction alternately in units of said predetermined capacity.